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Метод покрытия прямоугольниками объектов 
топологии микросхем, основанный 

на использовании обобщенной 

диаграммы Вороного 


Рассмотрена проблема покрытия многоугольников прямоугольниками, которая имеет место при подготовке 
входной информации для устройств, выполняющих изготовление фотошаблонов. Входная информация 
представляет собой описание последовательности прямоугольников. Выбор этой последовательности во 
многом определяет производительность этих устройств и качество получаемых фотошаблонов. 
Прямоугольники должны лежать полностью внутри многоугольника, и число их должно быть минимальным 
или близким к минимальному. Предложен простой эвристический алгоритм, основанный на использовании 
диаграммы Вороного, который покрывает многоугольник без дыр с острыми внутренними углами при 
помощи прямоугольников. 


Введение 


При производстве интегральных схем, фотоэлектрических преобразователей, ЖК- 
индикаторов, а также многих других микроэлектронных устройств возникает задача 
формирования топологических структур на металлизированных фотошаблонах [1]. Эти 
структуры формируются с помощью специальных генераторов изображений. Генераторы 
изображений строят топологию на фотошаблоне из наборных элементов. Наборный эле- 
мент представляет собой прямоугольник. Создание посредством таких генераторов про- 
извольных изображений топологических структур требует предварительного разло- 
жения (декомпозиции) этих структур на множество прямоугольников, объединение кото- 
рых с заданной точностью совпадает с описанием соответствующих исходных структур и 
формирует покрытие. При этом число прямоугольников, входящих во множество, должно 
быть минимальным или близким к минимальному. На основании полученного множества 
прямоугольников формируется оптимальная входная последовательность, которая коди- 
руется в соответствии с правилами входного языка соответствующего генератора изобра- 
жений. Задачи декомпозиции и, как частный случай, покрытия не являются новыми. 
Разработаны эффективные методы решения этих задач [1-9], однако при проектных нор- 
мах меньше 1 мкм возникают значительные трудности при генерации изображений, так 
как возрастает сложность топологии. 

Известные методы декомпозиции многоугольников можно разбить на перебор- 
ные [3-5] и сканирующие [1], [6-8]. Переборные методы просты в реализации, но 
оказываются эффективными лишь при покрытии односвязных и небольших по числу 
угловых точек контуров многосвязных областей. Методы сканирующего типа [10] 
являются эффективными как для односвязных, так и для многосвязных областей. 


«Штучний 1нтелект» 32009 367 


Воронов А.А. 
ЗВ е 


Эти методы дают возможность покрывать области как позитивного, так и негативного 
фотошаблона. Также используются комбинации этих методов [11]. Перечисленные 
выше методы являются приближенными, т.е. дают возможность получать решения, 
близкие к минимальному. 

В настоящей работе рассматривается оригинальный приближенный метод 
декомпозиции многоугольника в совокупность прямоугольников. Решение задачи 
декомпозиции осуществляется с использованием одной из модификаций диаграммы 
Вороного, называемой скелетом многоугольника [12]. Скелет многоугольника полу- 
чается из обобщенной диаграммы Вороного заменой параболических ребер хордами. 
Декомпозиция многоугольника начинается с его разбиения на ячейки по найденному 
скелету с целью покрыть каждую из этих ячеек прямоугольником. Если какая-либо 
из этих ячеек не покрывается прямоугольником, то она делится на более мелкие 
ячейки и т.д. Процесс декомпозиции завершается после того, как каждая из найден- 
ных ячеек будет покрыта прямоугольником. 


Метод декомпозиции 


Для решения задачи декомпозиции используются как специальные, так и 
универсальные алгоритмы. Специальные алгоритмы решают задачу покрытия окружно- 
стей, колец, шин, треугольников. Универсальный алгоритм решает задачу покрытия 
произвольного многоугольника. 

Универсальный алгоритм декомпозиции является эвристическим. Ниже приводится 
описание эвристического метода покрытия, являющегося развитием метода, описанного 
в работе [13]. Метод основан на использовании модификации обобщенной диаграммы 
Вороного, называемой скелетом многоугольника, и позволяет покрывать произвольные 
односвязные многоугольники. В процессе декомпозиции исходный многоугольник 
разбивается на всё меньшие и меньшие части, которые обрабатываются независимо 
до тех пор, пока каждая из этих частей не будет покрыта прямоугольниками, находя- 
щимися в пределах исходного многоугольника. Первое разделение достигается с 
помощью генерации скелета многоугольника, также называемого «средней осью». 

В отличие от диаграммы Вороного, которая строится для множества точек, 
скелет многоугольника (средняя ось) задает местоположение всех центров кругов, 
содержащихся в многоугольнике, которые касаются его границы в двух или более 
точках. Особенностью предлагаемого метода по сравнению с методом из работы [13] 
является то, что он позволяет находить покрытия для произвольных односвязных 
многоугольников, в том числе и с острыми внутренними углами. Для покрытия 
острых углов многоугольника применяется специальный алгоритм, который допол- 
няет основной метод. 

Предлагаемый ниже метод декомпозиции состоит из следующих этапов: 

1) формирование скелета исходного многоугольника; 

2) разбиение многоугольника по его скелету на ячейки; 

3) покрытие ячеек прямоугольниками. 

Последний этап метода выполняется для каждой ячейки, независимо от результата 
покрытия других ячеек. Каждая ячейка покрывается за время, линейное относительно 
числа ребер, включенных в нее. Последовательно рассмотрим каждый этап: 

1) формирование скелета для односвязного многоугольника. Рассмотрим 
задачу построения скелета для многоугольника. 
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Среди алгоритмов построения диаграммы Вороного для множества отрезков [14-16] 
следует выделить два алгоритма: Форчуна [15] и Ли [16]. Алгоритм Форчуна весьма 
сложен для реализации. Кроме того, в силу универсальности, он строит диаграмму 
Вороного не только внутри, но и вне многоугольника, что является для декомпозиции 
лишней работой. Более простой (и хронологически более ранний) алгоритм Ли строит 
диаграмму Вороного внутри многоугольника. Он основан на алгоритмической парадигме 
«разделяй и властвуй». Исходный многоугольник разбивается на две разомкнутые 
ломаные линии, для каждой из них рекурсивно строится диаграмма Вороного, а затем 
осуществляется объединение обеих диаграмм. На практике алгоритм Ли широко 
используется и работает достаточно надежно. Используемый ниже алгоритм форми- 
рования скелета многоугольника является модификацией алгоритма Ли [12]. Скелет 
используется для исследования топологических и метрических свойств области, что 
находит применение во многих методах анализа и распознавания изображений [17], [18]. 
Оценка вычислительной сложности задачи построения скелета многоугольника равна 
О(п), где п — число вершин многоугольника [7]. 

Для выполнения первого этапа метода декомпозиции используется диалоговая 
программа «Скелетизация многоугольной фигуры» [12]. 

Односвязный многоугольник — это замкнутая ограниченная область в евклидовой 
плоскости, границу которой составляет замкнутый контур, многоугольник без «дыр». 

Скелетом замкнутой области называется геометрическое место точек области, 
являющихся центрами максимальных по включению вписанных окружностей. 

Пример [. На рис. 1 приведен пример односвязного многоугольника, введенного 
и визуализированного средствами программы «Скелетизация многоугольной фигуры». 
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Рисунок 1 — Пример работы модуля реализующего первый шаг алгоритма 
для односвязного многоугольника 
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2) разбиение многоугольника на ячейки по его скелету. На первом шаге дан- 
ного этапа проводим анализ исходного многоугольника на наличие острых внутрен- 
них углов. Градусную меру вершины многоугольника определяем как величину 
угла, образованного прямыми, проходящими через эту вершину по сторонам, при- 
мыкающим к ней. 

Для острых углов выполняются следующие действия: восстановим перпенди- 
куляры из вершины скелета, ближайшей к вершине с острым углом, на стороны, об- 
разующие острый угол. Одновременно эти перпендикуляры являются радиусами 
окружности, а стороны, к которым они проведены, принадлежат прямым, касатель- 
ным к ней. Указанные перпендикуляры отсекают от исходного многоугольника че- 
тырехугольник с острым углом. 

Полученный четырехугольник обладает следующими свойствами. 

Стороны-перпендикуляры равны между собой как радиусы окружности. Сто- 
роны четырехугольника, примыкающие к перпендикулярам, также равны. 

Исходный многоугольник М разбивается на остроугольный четырехугольник и 
многоугольник Ли, у которого, по сравнению с многоугольником М, на один внут- 
ренний острый угол меньше. Повторяем эту процедуру и для многоугольника М/, 
если у него имеется хотя бы один внутренний острый угол и т.д. Процесс заверша- 
ется после получения многоугольника М», не содержащего внутренних острых 
углов. При этом будут получены и четырехугольников с острыми углами. 

Пример 2. Для рассмотренного выше в примере 1 скелета указанные преобра- 
зования применяются для вершин | и 11, так как углы при этих вершинах острые. 
В результате получим многоугольник, представленный на рис. 2. 
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Рисунок 2 — Пример скелета многоугольника 
с исключенными острыми углами 
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Четырехугольник с острым углом покрываем при помощи алгоритма, описанного 


в специальном подразделе. Для сформированного многоугольника М, без острых 
углов повторяем построение скелета и эффективной части скелета (часть скелета, не 
содержащая вершин, которые лежат на границе многоугольника). 

Ячейки для покрытия формируются по сторонам многоугольника или их отрезкам. 

Из каждой вершины эффективного скелета опускаем перпендикуляр на прямую, 
содержащую сторону многоугольника, и затем определяем, принадлежит ли проекция 
точки данной стороне-отрезку. Если проекция принадлежит стороне-отрезку, то пере- 
ходим к следующей вершине скелета, в противном случае — проецируем вершину ске- 
лета на прямую, содержащую следующую по порядку (обход против часовой стрелки) 
сторону многоугольника. 

Проверка принадлежности точки А(х,у) отрезку 2 с вершинами В(хьу/ и С(х>у2) 
выполняется следующим способом: 

точки отрезка 2 можно описать уравнением рОВ + (1-р)ОС =2, 0 <= р <=1, 
ОВи ОС - векторы. Если существует такое р, 0 <= р <= 1, что рОВ + (1-Р)ОС =А, 
то А лежит на отрезке, иначе - нет. Распишем в виде системы уравнений: 

рхь + 1 - р)х2 =х 
ру! + 1 —р)у2 =У. 

Из первого уравнения находим р, подставляем во второе: если получаем равен- 
ство и 0 <=р <= 1, то А на отрезке, иначе - нет. 

Пусть © будет отрезком многоугольника Р, который порождает ячейку. В ячейке 
может быть только три или четыре вершины, опускаем из каждой вершины эффектив- 
ного скелета перпендикуляр к соответствующей стороне многоугольника Р. Назовем 
сторону каждой ячейки, которая находится на стороне многоугольника Р, основой 
ячейки. Отрезки, которые перпендикулярны ее основе, — сторонами ячейки и границу 
ячейки, противолежащую ее основе, — вершиной ячейки. Ячейка является тривиально 
покрываемой наименьшим прямоугольником тогда и только тогда, когда одна сторона 
прямоугольника — основа ячейки, и прямоугольник покрывает ячейку таким образом, 
что сам полностью лежит в пределах многоугольника. 

Пример 3. Результат построения ячеек по эффективному скелету для рассма- 
триваемого многоугольника из примера 2 приведен на рис. 3. 


Рисунок 3 — Примеры формирования ячеек для многоугольника 
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3) покрытие ячеек при помощи прямоугольников. 


А ”› 
В” р р 
р р 
в С Б’ А В 
а) 6) с) 


Рисунок 4 — Примеры покрытия: а) покрытие ячейки порожденной вершиной; 
6) покрытие ячейки треугольника; с) ячейка — трапеция, 
угол (А, О, С) — по крайней мере 135° 


После исключения острых углов не все ячейки порождаются отрезками сторон 
многоугольника, потому что в получившемся многоугольнике некоторые углы боль- 
ше 180°, в исходном многоугольнике также возможны такие случаи. Так на рис. 4 а) изоб- 
ражена такая ячейка: вершина А соответствует вершине скелета 3 на рис. 2, вершина В 
соответствует вершине скелета 2 на рис. 2, вершина Ш) соответствует вершине скелета 4 
на рис. 2, а вершина С соответствует вогнутой вершине многоугольника (угол при кото- 
рой больше 180°) на рис. 2. Проводим прямую АС, через С проводим прямую а, перпен- 
дикулярную АС. Через А также проводим прямую, перпендикулярную АС. Опускаем 
из В и О перпендикуляры на последние две построенные прямые. Так находим коор- 
динаты вершин прямоугольника покрытия В’О’О”В”. 

Каждая ячейка обрабатывается независимо. Действие алгоритма описано от- 
дельно для различных типов ячеек. 

Ячейка-треугольник. 

Треугольник АВС полностью покрывается при помощи четырехугольника 
АВСР на рис. 4 6), так как угол при В прямой (СВ перпендикуляр к АВ). 

Прямоугольник покрытия находится полностью в пределах многоугольника Р, 
так как после исключения острых углов в многоугольнике нет острых углов и значит 
ячейки, которые имеют только три вершины, имеют тривиальное покрытие. 

Ячейка-трапеция 

Если ячейка — трапеция, тогда она является тривиально покрываемой. Иначе, пусть 
А, В, Си О будут вершинами ячейки в порядке против часовой стрелки, где Аи В -— 
конечные точки ее отрезка-основы. Пусть |АД] < |ВС | и основа горизонтальна и находится 
снизу. Теперь, если угол (А, О, С) больше или равен 135°, то мы утверждаем, что 
ячейка — тривиально покрываема. Пусть АВСЁ будет прямоугольник, который покрывает 
ячейку, рис. 4 с). Его часть АВНШО -— это прямоугольник и находится в пределах ячейки. 
Следовательно, он находится также в пределах многоугольника. 

Прямоугольник ОНСЕ -— это покрытие треугольника ОНС и находится внутри 
многоугольника, аналогично ячейке-треугольнику. Теперь нам остался один случай, 
когда угол (А, О, С) больше чем 90° и меньше чем 135°. Оценивая максимальную 
высоту любого прямоугольника в пределах многоугольника с основой АВ, можно 
сказать, что она будет > |ВС|, повернув ячейку вокруг ее вершины (с конечными 
точками Си 2), получим симметрическое изображение ячейки относительно ее вер- 
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шины, рис. 5. Пусть А’ и В’ будут симметрическим изображением А и В соответ- 
ственно. Пусть Е будет точкой на А’В' или на В’С, такой, что отрезок АЁ проходит 
через нее. Если |АЁ| > |ВС |, то ячейка тривиально покрываема. Еще остается рассмотреть 
случай |АЕ| < |ВС|. Сформулируем следующее определение. 

Если |АЕ| < ВС, то ячейка АВСР называется ячейкой-тоннелем для многоуголь- 
ника Р. Многоугольник, определенный вершинами АВСВ’А' (рис. 5), следующими в 
порядке против часовой стрелки, называется тоннелем. 


в 
Рисунок 5 — Пример образования ячейки-тоннеля 


Если |[АЁ <|ВС, то ЕЁ находится на А’В". Пусть а будет угол (А, О, С) минус 90°. 
Мы получаем, что угол (А', О, Е) = 2а. Кроме того, мы вычисляем |РЁ| = [АО |/соз (А’, О, 
Е). Так как |А'Б] = |АБ}, то из этого следует, что |АЕ| = АВ] + |РЕ| = |“Б*(+1соз 2 о). 
Определяем коэффициент тоннеля как (1+1/со$ 29). Теперь алгоритм разбивает ячейку 
на две подьячейки, АРЕ’О и ЕВСЕ', где ЕЁ' является параллельной АВ, и Е' лежит на ОС. 
Подьячейка АРЕ’О покрыта тривиально. Если подъячейка ЕВСЁ' не является тривиально 
покрываемой, то обрабатывается таким же образом, как ячейка-тоннель. Таким образом, 
первоначальная ячейка АВСРО в конечном счете разделена на [(15(|ВС/АР))/®; с] три- 
виально покрываемые подъячейки, где с — коэффициент тоннеля. 

Исходя из вышесказанного, мы можем сказать, что после построения скелета, за 
время О(и), любой многоугольник без дыр Р, кроме его ячеек-тоннелей, может быть 
покрыт О(и) прямоугольниками за время О(п). В пределах того же времени все 
ячейки-тоннели в Р, если они есть, могут быть обнаружены. В частности может быть 
О(п) ячеек-тоннелей в Р. 

Пример 4. Результат покрытия всех ячеек для многоугольника без острых углов 
из примера 3 приведен на рис. 6. 


Рисунок 6 — Пример покрытия прямоугольниками многоугольника 
с исключенными острыми углами 
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Покрытие четырехугольника с острым углом 
при помощи прямоугольников 


Для четырехугольника с острым углом используется следующий алгоритм его 
покрытия прямоугольниками. 

Производим построение первого прямоугольника, две вершины которого лежат 
на одной стороне острого угла четырехугольника — вершины М и Г, третья — на 
другой стороне — вершина 7, а четвертая — на биссектрисе острого угла (ребро 
скелета) — вершина М (рис. 7 а). Для следующего прямоугольника одной из вершин 
будет точка Х’— точка пересечения стороны построенного прямоугольника с биссект- 
рисой острого угла. Найдя ее, производим далее построение прямоугольника. 

Строим прямоугольники, исходя из указанной последовательности действий, 
на одной стороне острого угла четырехугольника до тех пор, пока меньшая сторона 
прямоугольника не станет меньше, чем величина 4 — минимально допустимый раз- 
мер, который может позиционировать лазерный генератор. Производим точно такое 
же построение прямоугольников на другой стороне угла (рис. 7 6). 


а) 6) 
Рисунок 7 — Пример четырехугольника с острым углом: а) 6) — покрытие его 


Оценка искажения, получаемого в рассмотренном выше алгоритме покрытия 
острого угла, равна величине (сё(0,5а), где 4 — минимально допустимый размер, 
который может позиционировать лазерный генератор, @ — величина острого угла [19]. 
С учетом технологии изготовления интегральных микросхем это искажение еще меньше. 
Острые углы, как правило, не функциональны, и подобная аппроксимация в них вполне 
допустима, а иногда даже и полезна [19]. 


Заключение 


Предлагаемый алгоритм решения задачи декомпозиции позволяет находить 
покрытие более высокого качества, так как за счет предварительной скелетизации много- 
угольника в результирующем покрытии минимизирована площадь взаимных пере- 
сечений прямоугольников, что снижает вероятность переэкспонирования резиста и, как 
следствие, его вздутия и выбраковки фотошаблонов. Следовательно, предлагаемый алго- 
ритм дает возможность формировать более качественные входные последовательности 
для генераторов изображений. 
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А.А. Воронов 

Метод покриття прямокутниками об’екпв топологй мкросхем, що грунтусться на використанн! 
узагальнено! даграми Вороного 

Розглянуто проблему покриття багатокутник!в, що виникае шд час шдготовки вхдно! 1нформаци для 
приладв, як! виконують виготовлення фотошаблонв. Вждна 1нформашщя являе собою опис послдовност! 
прямокутникв. Вибфр це! посллдовност! блльшою мрою визначае продуктивнсть цих приладв 1 яюсть 
отримуваних фотошабловв. Прямокутники повинн! знаходитися повнстю в середин! багатокутника, 1 
юальксть 1х повинна бути миимальною або близькою до миимально!. Запропонований простий евристичний 
алгоритм, що трунтуеться на використанн! даграми Вороного, який покривае багатокутник без дрок з 
гострими внутриин!ми кутами за допомогою прямокутникв. 


А.А. Уотопоу 

Метод ог Соуегто оЁТС Гауош РаЦбеги$ Бу Весёап?1е$ Вазе4 оп Уогопог$ О!аогат 

ТБе ргоМет оЁ соуетие роузопз Бу гесапе[ез фай {аКе расе ш шриё дав ргераганоп Юг ииеотае4 сисий 1ауой 
оепегаюгз 15 сопуегеа. Тприё даа 15 Че зефиепсе оЁтесапе]ез. ВаясаПу 1$ зедиепсе деегглите$ Фе ргодаснуйу оЁ 
Фезе ицеогае4 сисий |ауойё оепегаюг ап4 диаШу оЁ ошри рБоюглазК. ТБе гесапез плиз Пе епйге]у ут Фе 
роухоп апа 1 1 ргеЕгаЫе © соуег Фе роугоп УЛ аз Ее\\ тесбапз!ез аз розу е. Те знаре Бейнс а|еог ит, Базе 
оп Фе УогопоГ 5 Фаотапл$, фай соуег пое-Яее роухоп у асще пщепог ап?1ез Бу гесбапе]е$ 1$ ргезетщед. 
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